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METHOD AND APPARATUS FOR RETRIEVING TIME SERIES DATA 

RELATED TO AN ACTIVITY 

FIELD OF THE INVENTION 

This invention relates to a method and apparatus for processing time 
series data of a process. In particular, the method and apparatus of the present 
invention is concerned with gathering, storing and retrieving time series data of a 
process. 
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BACKGROUND OF THE INVENTION 

A process takes place over a period of time. During the process various 
events occur and various parameters vary in value. There is a need to monitor 
5 a process in order to analyze its performance or of any parameters thereof, 
whether the process is an industrial one for the handling, treatment or flow of 
material or other process, such as the tracking of the weather or of commodities 
or other financial instruments and the like. 



1 0 Current monitoring and processing systems monitor and store events that 

occur during the process and time sampled values (time series data) of the time 
C3 variable parameters of the process. It is necessary to retrieve the process data 

for analysis and reports, for example, trending analysis and reports. The current 
systems have difficulty in retrieving events and time series data of a process. 
15 Generally, custom designed filtering systems are used to determine the events 
and time series data of interest. 
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Thus, there is a need for a flexible and efficient method and system for 
processing data that is relevant to a process. 
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SUMMARY OF THE INVENTION 

The method of the present invention frames time series data of a process 
with one or more activities. An activity is something that happened, happens or 
is planned to happen over a period of time. The period of time or interval of the 
activity frames time series or continuous data associated with the happening. 
An activity may have one or more sub-activities, which may have one or more 
sub-sub-activities and so on, thereby resulting in a multi-tier hierarchy. 

In a first embodiment of the method of the invention, the time series data 
of a process is collected. The time series data is processed according to a data 
structure that defines an activity and an interval thereof. The processed time 
series data is stored in a memory. 

A second embodiment of the method of the invention retrieves time series 
data of a process that is stored in a memory. An activity of the process and a 
time varying parameter of the process are identified. The activity and the time 
varying parameter are processed to access the memory to retrieve the time 
series data. In particular, the activity and the time varying parameter are 
processed according to a data structure in which the activity has an interval that 
frames the time series data. 

According to one aspect of the first and second embodiments of the 
method, the data structure includes an identity or name of the activity and one or 
more attributes of the activity. According to another aspect of the first and 
second embodiments of the method, the attributes identify the start and end 
times of the activity. Some of the attributes identify a time varying parameter 
and/or an item or an equipment or device thereof used in the process. For 
another aspect of the first and second embodiments of the method, the data 
structure includes a tag that identifies a device that will produce the time series 
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data when the process is run. According to another aspect of the first and 
second embodiments of the method, the attributes have attribute values. 

According to another aspect of the second embodiment of the method of 
the invention, the time varying parameter is simply identified as an item or a 
device that produced the time series data. Another attribute identifies something 
used by or in the process, for example, equipment. The equipment attribute 
may have different attribute values for different parts thereof that may be linked 
to time varying parameters and device tags. 

According to still another aspect of the second embodiment of the 
method, the time varying parameter is identified with a reference that is either 
time based, direct or indirect with respect to the activity. The time based 
reference is with respect to a parameter that is independent of the process. The 
direct reference contains a reference by identity to the activity, the indirect 
reference contains a reference to equipment or a device that is used by the 
process during the activity. 

A first and second embodiment of an apparatus of the present invention 
comprises a computer that performs the method of the first and second 
embodiments of the method of the invention. 

According to a third embodiment of the method of the present invention, 
the activity interval frames the time series data. The time series data is 
processed according to the data structure for storage in a memory. The activity 
and the time varying parameter are processed to access the memory and 
retrieve the time series data. 



PATENT 

Attorney Docket No. 120 01530 US 

A third embodiment of an apparatus of the present invention comprises 
computer that performs the method of the fourth method embodiment of the 
invention. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

Other and further objects, advantages and features of the present 
invention will be understood by reference to the following specification in 
5 conjunction with the accompanying drawings, in which like reference characters 
denote like elements of structure and: 

Fig. 1 is a block diagram of a system of the present invention for 
processing time series data; 
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Fig. 
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is a block diagram of the computer of the Fig. 1 system; 



Fig. 
activities; 
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depicts an exemplary process, its events, time series data and 
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Fig. 
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depicts an activity diagram for the Fig. 3 process; 



Fig. 
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depicts a data and event diagram for the Fig. 3 process; 
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Figs. 6-8 depict data structures for activity framed time series data; 



Figs. 9-1 1 depict data structures for activity framed event data; 



Fig. 12-14 depict data structures for activity framed activity data; and 
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Figs. 15-19 are flow diagrams of the activity framing program of the 
computer of Fig. 2. 
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DESCRIPTION OF THE PREFERRED EMBODIMENT 

Referring to Fig. 1 , a system 20 of the present invention includes a 
computer 22, a monitor 24 and a database 24. A network 30 interconnects 
5 computer 22 and database 26 as well as a client device 32. Monitor 26 monitors 
a process 28 and provides process data to computer 22. Computer 22 
processes the data and stores the data in a memory, such as database 26. 
Computer 22 may communicate with database 26 via network 30 or directly, as 
shown by the dashed line 34. 

10 

Database 26 may be a part of the memory of computer 22 or a separate 
J3 database, as shown in Fig. 1 . Computer 22 may be a single computer or a 

fU plurality of computers interconnected via network 30. Network 30 may be any 

m 

suitable wired or wireless communication network and may include the Internet 
W 15 an Intranet, the public telephone system and the like. 

issr 

2 

ij", Client device 32 may be any suitable computer entry device with a 

FU capability to communicate with computer 22 via network 30. For example, if 

q network 30 is the Internet, client device 32 has a browser capability for Internet 

20 communications. As such, client device 32 may be a personal computer (PC), a 
workstation, a phone or other suitable device. Similarly, computer 22 would be 
equipped with Internet capability to serve files and/or otherwise communicate via 
the Internet. 

25 Referring to Fig. 2, computer 22 includes a processor 34, a 

communications unit 36, a memory 38 and a bus 40. Bus 40 interconnects 
processor 34, communications unit 36 and memory 38. Memory 38 includes an 
operating system 42 and an activity framing program 44. Operating system 42 
controls processor 34 to execute activity framing program 44 to process data of 

30 process 28 monitored by monitor 24. A memory media 46 (e.g., a disk) contains 
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a copy of operating system 42, activity framing program 44 or other software, 
which can be loaded into memory 38. Communications unit 36 includes the 
capability to communicate via network 30. 

5 Activity framing program 44, when run, permits a client to operate client 

device 32 to identify process 28 in terms of events, time variable parameters 
and activities. An event is something that happens at a specific time, for 
example, the triggering of an alarm. Time series data is continuous data of a 
time variable parameter, such as temperature, pressure, flow rate and the like. 
10 An activity is a time interval of the process, for example, the operation of a pump 
during the process. 

Activity framing program 44, when run, allows the monitored time series 
data, event data and/or activity data to be framed by defined activities for later 
1 5 retrieval and access based on the defined activity, attributes thereof and tag 
(identity) of the device that develops the time variable data, e.g., a temperature 
sensor. 

For the purpose of describing the apparatus and method of the invention, 
20 an exemplary process that unloads a material, such as oil, from a ship will be 
initially described. It is understood, of course, that the system and method of 
the invention can be used with any process that has events, time variable 
parameters and/or activities that can be framed by a defined activity. 

25 Referring to Fig. 3, a system 50 is shown for running process 28 for 

pumping out material from a ship 52 into a pair of holding tanks, Tank 1 and 
Tank 2. Ship 52 has a level indicator LI001 that monitors the material level in 
ship 52 during pump out process 28. A temperature monitor T101 monitors the 
outside ambient temperature as it can affect pumping performance. Material is 

30 pumped from ship 52 through pipes 54 and passes by a density analyzer A1 001 . 

8 
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The material is pumped to Tank 1 and Tank 2 by a pair of pumps, P101 and 
P102. When a valve V101 is open, the material is pumped by pump P101. 
When a valve V102 is open, the material is pumped by pump P102. A valve 
V103 controls the flow of material to Tank 1 and a valve V104 controls the flow 
5 of material to Tank 2. Flow rate to Tank 1 is monitored and controlled a flow 
analyzer FI1001 . Flow rate to Tank 2 is monitored and controlled by a flow 
analyzer FI1002. A level indicator L1 101 monitors the level of material in Tank 1 
and a level indicator L1 102 monitors the level of material in Tank 2. A motor 
M101 controls an agitator 54 in Tank 1 and a motor M102 controls an agitator 56 
10 in Tank 2. 



□ 
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In system 50, the following constraints apply: 



fn 

rv a. Contents of ship 52 do not fit into a single tank. 

CO 1 5 b. Only one tank can be filled at a time. 



c. Only one pump can be used at a time. 

Referring to Fig. 4, a number of activities are defined for the pump out 
process of ship 52. The execution of the activities begins at a time TO and 
completes at a time Tn. These activities are as follows: 

1 ) Analyze activity - This activity continuously mofiitors analyzer A1 001 
throughout the pump out process from time v) to time Tn and alerts an 
operator if the material density is outside of a specified range. 

2) Unload Ship activity - This activity is a procedure for initiating and 
monitoring the pump out of ship 52. It is the master procedure 
responsible for initiating sub activities: Pumpoutl , Pumpout2, Pumpout3, 
Mix1, and Mix2. 



30 
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3) Pumpoutl , Pumpout2, Pumpout3 activities - These three pump out 
activities are of the same type, but each uses different settings. A pump 
out activity stops when a tank is full or a failure (e.g. pump failure) occurs. 
In such case, the higher-level activity Unload Ship is responsible to 
schedule another pump out activity with the appropriate settings until ship 
52 is empty. Activity Pumpoutl moves material from ship 52 to Tank 1 . 
Activity Pumpoutl stops when Tank 1 is full. Activity Pumpout2 pumps 
material from ship 52 to Tank 2. Activity Pumpout2 stops when pump 
P101 fails. Activity Pumpout3 uses pump P102 and continues pumping 
material to Tank 2 until ship 52 is empty. 

4) Mix 1 activity - This activity is a procedure responsible for activating 
agitator 54 for Tank 1 . Agitator 54 starts during activity Pumpoutl and 
runs for a period of time after the completion of activity Pumpoutl . 

5) Mix 2 activity - This activity is a procedure responsible for activating 
agitator 56 for Tank 2. Agitator 56 starts during activity Pumpout2 and 
runs for a period of time after the completion of activity Pumpout2. 

These activities can be expressed in a hierarchical order of activity, sub- 
activity and sub-sub-activity as shown in Table 1 . 



TABLE 1 



Activity 


Unload Ship 


Sub-activity 


Pumpoutl 


Sub-sub-activity 


Mix1 


Sub-activity 


Pumpout2 


Sub-sub-activity 


Mix2 


Sub-activity 


Pumpout3 
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Sub-sub-activity 



Mix2 



Referring to Fig. 5, a curve 60 represents the material level in ship 52 
(i.e., the values of level sensor LI001) during the activity Unload Ship. Curve 62 
represents the material level in Tank 1 (i.e., the values of level sensor LI101) 
5 during the sub-activity Pumpoutl . Curve 64 represents the material level in 
Tank 2 (i.e., the values of level sensor LI102) during sub-activity Pumpout2. A 
curve 66 represents the ambient temperature (i.e., the values of temperature 
sensor T101) during the activity Unload ship. A curve 68 represents the flow 
rate of material as monitored by flow rate sensor FI1001 during sub-activity 
u 1 0 Pumpoutl . A curve 70 represents the flow rate of material as monitored by flow 
y rate sensor FI1001 during sub-activity Pumpout2. A curve 72 represents the 

fU flow rate of material as monitored by flow rate sensor FI1002 during sub-activity 

^ Pumpout3. As can be seen, the outputs of level sensors LI001 , L1 101 and L1 102 

M and of flow rate sensors FI1001 and FI1002 vary with time and are continuous 

s 15 or time series data. 

ill 

S tff 

rU Figs. 3-5 show the execution of the activities and sub-activities required 

q to pump out ship 52 over a period of time. At time TO, an instance of activity 

Unload ship is created. The operator would give the instance a name, for 
20 example, UNLOAD_2001_06_01 . The operator would then initiate the activities 
in either an automated or manual manner. 



•ssar 



As the activities are initiated, the process data shows a plurality of events 
74, 76 and 78 that occur during the pump out process. Event 74 represents a 
25 flow change initiated by the operator to increase the flow rate during sub-activity 
Pumpoutl . This flow rate change is monitored by sensor FI1001 . Event 76 
represents a temperature alarm detected when the ambient air temperature 
drops below a safe pump operating range during sub-activity Pumpout2. Event 
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78 represents a failure of pump P101 during sub-activity Pumpout2. As a result 
of the failure of pump P101 , the process switches to the second pump P102. 

Process 28 is initially defined as a data structure that has identified 
5 activities, sub-activities, sub-sub-activities, attributes, resources (e.g., sensors). 
Throughout the processing of the activities, sub-activities and sub-sub-activities 
of process 28, data is collected pertaining thereto, including time series data and 
event data. The apparatus and method of the present invention uses the data 
structure of activities, sub-activities and sub-sub-activities to frame time series 
10 data, event data and activity data. The framed data can then be processed, 

stored and retrieved based on the identity of the activity, sub-activity or sub-sub- 

□ activity, attributes thereof and/or the sensor that monitored the data. Time 

£3 

ry series data can be related to an activity based on time, direct reference or 

;\ indirect reference. These relations will be described with reference to the 

CO 1 5 unload ship process example. 

The case of time series data related to an activity based on time will be 

til 

ry described with reference to Fig. 6. Sub-activity Pumpoutl has two attributes, 

!=& 

1*, namely a start time and an end time. Each of these attributes has an attribute 

l al 20 value. Thus, the start time value is August 17, 2000 at 10:00am and the end 
time value is August 17, 2000 at 10:30am. The ambient temperature is not 
directly or indirectly related to the sub-activity Pumpoutl . It is a general reading 
for the whole site and any activity run, or any equipment being used. The time 
series temperature data is related to the time of sub-activity Pumpoutl . Thus, to 
25 process, store or retrieve the time series temperature data monitored by 
temperature sensor T101 , the identities of the sub-activity Pumpoutl and 
temperature sensor T1 01 are used. 

The case of time series data related to an activity based on direct 
30 reference will be described with reference to Fig. 7. An activity can have an 
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attribute that is tied to a sensor value (i.e. the value of this attribute is not a 
single value, but its value changes overtime). In Fig. 7, Sub-activity Pumpoutl 
has an additional attribute, namely flow rate. The flow rate is tied to flow rate 
sensor FI1001 . The sensor identity (FI1001) is referred to herein as a tag. By 
5 giving an attribute a name (flow rate) and a sensor thereof a tag (FI1001 ), the 
same attribute (flow rate) can be used for the flow rate variable for a lot of 
different flow rate sensors. The time series data of flow rate sensor FI101 is 
related to sub-activity Pumpoutl by direct reference to the identities of the sub- 
activity, the attribute and the tag of the sensor. Thus, to process, store and 
10 retrieve the time series data monitored by flow rate sensor FI1001 , the identities 
of the sub-activity, the flow rate attribute and the tag of the sensor are used. 

C3 The direct reference case is an option that is used most often in a flexible 

£3 

?U system where devices are allocated at a granular level (e.g. at the pump level, 

as opposed to an equipment unit level, i.e. with all the devices built onto the 
15 equipment). 

The case of time series data related to an activity based on indirect 
reference will be described with reference to Fig. 8. An activity can have an 
attribute that identifies equipment that is used by the activity. On this 
20 equipment, the user can define a plurality of equipment attributes for different 
parts of the equipment, with each part attribute being tied to a sensor by a tag. 
In Fig. 8, the sub-activity Pumpoutl has an attribute (equipment) that has an 
attribute value for an equipment part, namely Tankl . Attribute value (Tank 1) 
refers to an equipment (Tank 1) that has an attribute (Level) with an associated 
25 tag (sensor LI101). Thus, an indirect reference through the equipment attribute 
and sub-activity can be used to access time series data of a part of the 
equipment. This option is used most often when a complete equipment unit, 
with all the devices built onto it, is allocated for use by an activity, sub-activity 
and so on. 

30 
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Event data can also be related to an activity based on time, direct 
reference or indirect reference. The case of event data related to an activity 
based on time will yield all events that happened during the activity. 

Referring to Figs. 5 and 9, a time based retrieval request for events that 
happened during the activity PumpOut 2 identifies temperature alarm 76. The 
retrieval shows that temperature alarm 76 occurred at 10:20am on August 20, 
2000 during sub-activity PumpOut 2. 

Referring to Fig. 10, a retrieval request for event 74 (Fig. 5) by direct 
reference to an activity or sub-activity identifies the sub-activity Pumpoutl and 
results in a retrieval of data for events that occurred during the sub-activity. 

Referring to Figs. 5 and 1 1 , event 78 (Fig. 5) and activity Pumpout2 can 
be indirectly related to each other because they use the same equipment 
(referenced by one of their event/activity attributes). 

An activity can also frame one or more other activities. That is, an activity 
can overlap another activity in whole or in part. An activity can be accessed by 
a time based reference, a direct reference or an indirect reference. 

Referring to Fig. 12, a retrieval request for those activities that are related 
to a first activity by a time based reference identifies the first activity by name 
(Pumpout3) and essentially requests data of any activity that occurs entirely or 
partly during the time of activity Pumpout3. The retrieval identifies the sub-sub- 
activity of Pump Repair. 

Referring to Fig. 13, a retrieval request for an activity by direct reference 
identifies all activities that have a direct reference thereto. Thus, if the request 
identifies the activity Unload Ship, data for the activity Analyze is retrieved. 
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Referring to Fig. 14, a retrieval request for an activity by indirect reference 
identifies an equipment attribute and value of Tank 1 thereof. The retrieval 
reveals the sub-activity of Pumpoutl and the sub-sub-activity Mix1 . 

5 

Referring to Fig. 15, activity program 44 permits a user to define a 
process in terms of the activity/event/time series data structure. For example, 
the definitional data can be developed and identified during an interactive 
session between computer 22 and client device 32 operated by the user. Step 
10 100 identifies the activities, sub-activities, sub-sub-activities and so on of the 
^ process. Step 102 identifies activity type attributes, such as start times and end 

□ times, time variable parameters (e.g., flow rate), equipment and tags. That is, 

C3 

ry step 102 defines the attributes of an activity that frames an event, a time varying 

jr\; parameter or another activity. Step 1 04 accepts activity types defined by step 

SO 15 1 00 and the attributes defined by step 1 02 for entry. 

s 

Step 106 identifies event types, such as temperature alarm 76. Step 108 
rU identifies event type attributes, such as a time stamp (Fig. 9). Step 110 accepts 

' n event types defined by step 1 06 and the attributes defined by step 1 08 for entry. 

H= 20 Step 112 identifies tags for sensors the monitor time series data. Step 114 
accepts the tags defined by step 112. Step 116 stores the data accepted by 
steps 104, 110 and 1 14 in data base 26 in a manner that permits access by 
activity, event, attributes of either and/or tags. For example, database 26 may 
be physically or logically organized by activity, event, attributes of either and/or 
25 tags. If logically organized, a storage access translator would be used to 
translate the activity, event, attributes of either and/or tag access data into 
physical storage volumes. 

Referring to Fig. 16, activity program 44 also permits the collection of 
30 data during the running of the process, such as process 28. Step 120 identifies 
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that the process has been initiated by the operator or automatically by a control 
system. Step 122 executes activities, such as Pumpoutl (Figs. 4, 6-10 and 14). 
That is, step 122 processes the activity so as to frame the time series data and 
event data collected with an interval of the activity. Step 124 determines when 
5 the step 122 is finished. Step 130 closes the collection of activity data. 

Step 126 creates an activity history record, such as attribute values (e.g., 
start time and end time). Step 128 collects event happenings, time stamps and 
the like for events, such as temperature alarm 76. Step 132 processes the 
10 event happenings and links them to activities of any tier. Step 134 collects time 
u series data monitored by the various sensors of the process. 

ry Step 136 stores the activity, event and time series data in database 26 for 

jrj? retrieval by activity, attribute thereof and/or tag. Step 138 retrieves the data 

£0 15 activity, event, attribute and/or sensor tag for processing or analysis. 

J* Referring to Fig. 17, time series data of process 28 is retrieved from 

FU database 26 by activity framing program 44, for example, via an interactive 

* n session with a user operating client device 32. Step 140 identifies an activity 

20 specified by the user. The activity is matched to the data structure thereof, 
which reveals the attribute that contains a start time and an end time. 

Step 142 identifies a time varying parameter of process 28. If the time 
varying parameter, for example, the ambient temperature, is unrelated to the 
25 activities of the process, a tag identifies it. If the time varying parameter is 

directly related to the identified activity, it will be an attribute of the matched data 
structure and will have the associated tag for the device that monitors the time 
series data of the identified time varying parameter. Alternatively, if the time 
varying parameter is indirectly related to the activity, the data structure contains 
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an equipment attribute. The equipment attribute identifies an equipment part, 
time varying parameter and tag for the device. 

Step 144 processes the activity and time varying parameter into a form 
5 suitable for accessing the time series data of the time varying parameter. For 
example (with reference also to Fig. 7), if the user identifies the flow rate during 
the PumpOut 1 activity, step 144 presents the request in a form useable to 
access database 26. Step 146 then accesses database 26 to retrieve the time 
series data of the flow rate during the PumpOut 1 activity. 

10 

u Referring to Fig. 18, event data of process 28 is retrieved from database 

r • 

O 26 by activity framing program 44, for example, via an interactive session with a 

fy user operating client device 32. Step 160 identifies an activity, for example 

12 PumpOut 1 or PumpOut 2, specified by the user. The activity is matched to the 

CO 1 5 data structure thereof, which reveals the attribute that contains a start time, an 

7*' end time and an equipment. 

u 
iy 

fU Step 162 identifies an event of process 28. If step 162 is identifying an 

i « 

p event that is not directly related to process 28 based on a time reference, all 

H 20 such events that happened during the interval of the activity will be identified. 

For example, if step 160 identifies the activity of PumpOut 2, step 162 will then 
identify temperature alarm 76 and Pump 1 Failure 78 as events that occur 
during the interval of PumpOut 2 (Figs 5 and 9). 

25 If step 1 62 is selecting an event that has a direct reference to the activity, 

all events having an attribute that refers to the activity will be selected. For 
example, if step 160 identifies the activity as PumpOut 1 and step 162 requests 
events by direct reference, step 162 will then identify the event of Pump Speed 
change 74 (Fig. 10). 

30 
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If step 162 is selecting an event by indirect reference to the activity, all 
events that happened on a given equipment while it was being used by the 
activity will be selected. For example, if step 160 identifies the activity of 
Pumpout 2 and step 162 requests events by indirect reference, the event of 
5 Pump 1 Failure 78 will be identified (Fig. 11). 

Step 164 processes the activity and event into a form suitable for 
accessing the event data of the event. Step 1 66 accesses database 26 to 
retrieve the event data of the event that occurred during the interval of the 
1 0 activity. 

lei 

Q Referring to Fig. 19, activity data of process 28 is retrieved from database 

£3 

ry 26 by activity framing program 44, for example, via an interactive session with a 

r; user operating client device 32. Step 170 identifies an activity, for example 

CO 15 Unload Ship, PumpOut 1 or Pumpout 3 (Figs. 5 and 12-15), specified by the 
~ user. The activity is matched to the data structure thereof, which reveals the 

1* attribute that contains a start time, an end time and an equipment. 

- ™ , 

Step 172 identifies a related activity of the activity identified by step 170 
H 20 that is to be framed. If the related activity is related to the activity based on a 
time reference, all related activities that happened entirely or partly during the 
interval of the activity will be selected. For example, if step 170 identifies the 
activity of PumpOut 3 (Figs. 5 and 12) and step 172 requests related activities 
by a time based reference, step 172 will identify the activity of Pump Repair that 
25 happened partly during the interval of activity PumpOut 3 (Fig. 12). 

If the activity to be framed is directly related to the activity identified by 
step 170, all related activities that have a reference thereto will be selected. For 
example, if step 170 selects the activity of Unload Ship, the related activity of 



18 



PATENT 

Attorney Docket No. 120 01530 US 

Activity Analyze will be selected (Fig. 13) as it has an attribute value that refers 
to activity of Unload Ship. 

If the activity to be framed is indirectly related to the activity identified by 
step 170, all related activities that occur entirely or partly during the activity 
interval and that reference the same equipment as the equipment referenced by 
the activity will be selected. For example, if step 170 identifies the activity 
PumpOut 1 that refers to Tank 1, related activity Mix 1 that also refers to Tank 1 
will be identified (Fig. 14). 

Step 174 processes the activity and the related activity into a form 
suitable for accessing the data of the related activity. Step 176 accesses 
database 26 to retrieve the data of the related activity for the interval of the 
activity. 

The present invention having been thus described with particular 
reference to the preferred forms thereof, it will be obvious that various changes 
and modifications may be made therein without departing from the spirit and 
scope of the present invention as defined in the appended claims. 
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